#### Fall 2021

# **Solutions - Homework 3**

(Due date: November 3rd @ 5:30 pm)

Presentation and clarity are very important! Show your procedure!

## PROBLEM 1 (10 PTS)

• Complete the timing diagram for the flip flop and the latch shown below: (6 pts)



- Complete the timing diagram of the circuit shown below. (4 pts)



```
Q_{t+1} \leftarrow T \oplus Q_t
```

### PROBLEM 2 (23 PTS)

Complete the timing diagram of the circuit shown below: (7 pts)



• Complete the timing diagram of the circuit shown below: (6 pts)



# ELECTRICAL AND COMPUTER ENGINEERING DEPARTMENT, OAKLAND UNIVERSITY ECE-2700: Digital Logic Design

Complete the timing diagram of the circuit shown below: (10 pts)



#### PROBLEM 3 (17 PTS)

- With a D flip flop and logic gates, sketch the circuit whose excitation equation is given by (4 pts):
  - $\checkmark \quad Q(t+1) \leftarrow x\overline{Q(t)} + (\overline{y} \oplus \overline{Q(t)})$



- Given the following circuit: (8 pts)
  - ✓ Get the excitation equations for each flip flop output.
  - ✓ Complete the timing diagram of the circuit.  $Q = Q_3 Q_2 Q_1 Q_0$ .



• Complete the timing diagram of the circuit whose VHDL description is shown below. Also, get the excitation equation for q.



#### PROBLEM 4 (14 PTS)

• Given the following circuit, complete the timing diagram (signals *DO*, *Q*, and *DATA*). The LUT 6-to-6 implements the following function:  $OLUT = [ILUT^{0.79}]$ , where ILUT is a 6-bit unsigned number. For example:  $ILUT = 35 (100011_2) \rightarrow OLUT = [35^{0.79}] = 17 (010001_2)$ 



#### PROBLEM 5 (20 PTS)

- For the following circuit (4-bit parallel/serial load shift register with enable input) we have:  $Q = Q_3 Q_2 Q_1 Q_0$ .  $D = D_3 D_2 D_1 D_0$ . When E=1: If  $s_1=0$  (shifting operation). If  $s_1=1$  (parallel load).s
  - ✓ Write a structural VHDL code. You MUST create a file for: i) flip flop, ii) MUX 2-to-1, and iii) top file (where you will interconnect the flip flops and MUXes). (10 pts)
  - ✓ Write a VHDL testbench according to the timing diagram shown below. Complete the timing diagram by simulating your circuit (Behavioral Simulation). The clock frequency must be 100 MHz with 50% duty cycle. (10 pts)
- Upload (as a .zip file) the following files to Moodle (an assignment will be created):
  - ✓ VHDL code files and testbench
  - $\checkmark$  A screenshot of your simulation showing the results for Q (this is on top of you completing the timing diagram below).

```
VHDL Code: Top File
library IEEE;
use IEEE.STD LOGIC 1164.ALL;
entity my st shiftreg is
    generic (N: INTEGER:= 4;
             DIR: STRING:= "RIGHT"); -- RIGHT/LEFT
    port (D: in std_logic_vector (N-1 downto 0);
          resetn, clock, din, E, s l: in std logic;
          Q: out std logic vector (N-1 downto 0));
end my_st_shiftreg;
architecture structure of my_st_shiftreg is
  component dffe
    port ( d : in STD LOGIC;
            clrn, prn, clk, ena: in std logic;
            q : out STD LOGIC);
  end component;
  component mux2to1
    port (a,b, sel : in std logic;
           y : out std logic);
  end component;
  signal ds, md, Qt: std logic vector (N-1 downto 0);
begin
```

Fall 2021

```
a0: assert (DIR = "LEFT" or DIR = "RIGHT")
    report "DIR can only be LEFT or RIGHT"
    severity error;
rr: if DIR = "RIGHT" generate
        ds(N-1) <= din;
        ds(N-2 downto 0) <= Qt(N-1 downto 1);
    end generate;
rl: if DIR = "LEFT" generate
       ds(0) \leq din;
        ds(N-1 downto 1) <= Qt(N-2 downto 0);
    end generate;
ti: for i in N-1 downto 0 generate
       fi: dffe port map (d => md(i), clrn => resetn, prn =>'1', clk => clock, ena => E, q => Qt(i));
       mi: mux2to1 port map (a => ds(i), b => D(i), sel => s l, y => md(i));
    end generate;
    Q <= Qt;
end structure;
 VHDL Code: D-Type flip flop
                                                         VHDL Code: MUX 2-to-1
 library IEEE;
                                                         library IEEE;
 use IEEE.STD LOGIC 1164.ALL;
                                                         use IEEE.STD LOGIC 1164.ALL;
 use IEEE.STD LOGIC UNSIGNED.ALL;
                                                         entity mux2to1 is
 entity dffe is
                                                             port (a,b, sel: in std logic;
                                                                  y : out std logic);
     port ( d : in STD LOGIC;
                                                         end mux2to1:
            clrn, prn, clk, ena: in std logic;
            q : out STD LOGIC);
 end dffe:
                                                         architecture structure of mux2to1 is
 architecture behaviour of dffe is
                                                         begin
 begin
                                                              with sel select
                                                                      y \leq a when '0',
     process (clk, ena, prn, clrn)
     begin
                                                                           b when others;
        if clrn = '0' then q \leq '0';
         elsif prn = '0' then q <= '1';
                                                      end structure;
        elsif (clk'event and clk='1') then
           if ena = '1' then q <= d; end if;
        end if;
      end process;
 end behaviour;
VHDL Tesbench:
LIBRARY ieee;
USE ieee.std logic 1164.ALL;
ENTITY tb_my_st_shiftreg IS
    generic (N: INTEGER:= 4);
END tb my st shiftreg;
ARCHITECTURE behavior OF tb my st shiftreg IS
    COMPONENT my st shiftreg
    PORT( D : IN std_logic_vector(N-1 downto 0);
          resetn, clock, din : IN std logic;
          E, s l : IN std_logic;
          Q : OUT std logic vector(N-1 downto 0));
    END COMPONENT;
   --Inputs
   signal D : std logic vector(N-1 downto 0) := (others => '0');
   signal resetn : std logic := '0';
   signal clock : std_logic := '0';
   signal din : std logic := '0';
   signal E : std_logic := '0';
   signal s l : std logic := '0';
    --Outputs
   signal Q : std logic vector(N-1 downto 0);
   -- Clock period definitions
```

#### ELECTRICAL AND COMPUTER ENGINEERING DEPARTMENT, OAKLAND UNIVERSITY ECE-2700: Digital Logic Design

```
constant T : time := 10 ns;
BEGIN
    -- Instantiate the Unit Under Test (UUT)
   uut: my_st_shiftreg PORT MAP (D => D, resetn => resetn, clock => clock, din => din,
                                 E => E, s_1 => s_1, Q => Q);
   -- Clock process definitions
   clock process: process
   begin
      clock <= '0'; wait for T/2;</pre>
      clock <= '1'; wait for T/2;
   end process;
   -- Stimulus process
   stim proc: process
  begin
    resetn <= '0'; wait for 100 ns;</pre>
    D <= "1000"; din <= '1'; E <= '0'; s l <= '1'; wait for T;
    resetn <= '1';</pre>
    D <= "1000"; din <= '1'; E <= '1'; s l <= '1'; wait for T;
    D <= "1000"; din <= '0'; E <= '1'; s l <= '0'; wait for T;
    D <= "1010"; din <= '0'; E <= '1'; s l <= '1'; wait for T;
    D <= "1010"; din <= '1'; E <= '1'; s l <= '1'; wait for T;
    D <= "1010"; din <= '1'; E <= '1'; s_l <= '1'; wait for T;
    D <= "1010"; din <= '0'; E <= '0'; s l <= '1'; wait for T;
    D <= "1101"; din <= '1'; E <= '0'; s_l <= '0'; wait for T;
    D <= "1101"; din <= '0'; E <= '1'; s l <= '0'; wait for T;
    D <= "1101"; din <= '0'; E <= '1'; s l <= '1'; wait for T;
    D <= "1110"; din <= '0'; E <= '1'; s l <= '1'; wait for T;
    D <= "1110"; din <= '1'; E <= '1'; s_1 <= '0'; wait for T;
    D <= "1110"; din <= '1'; E <= '1'; s l <= '1'; wait for T;
    D <= "1110"; din <= '0'; E <= '0'; s_l <= '1'; wait for T;
    D <= "1011"; din <= '0'; E <= '1'; s l <= '1'; wait for T;
    D <= "1011"; din <= '1'; E <= '1'; s_1 <= '0'; wait for T;
    D <= "1011"; din <= '0'; E <= '1'; s l <= '1'; wait for T;
    wait;
  end process;
END;
                                                                             ▲Q<sub>1</sub>
                              Q3
                                                      Q_2
resetn
                                                                     0
                      ტ
                                              Ċ
```



5

### **PROBLEM 6 (8 PTS)**

- Complete the timing diagram (output DO) of the following Random Memory Access (RAM) Emulator.
- RAM Emulator: It has 8 addresses, where each address holds a 4-bit data. The memory positions are implemented by 4-bit registers. The resetn and clock signals are shared by all the registers. Data is written or read onto/from one of the registers (selected by the signal address).
- **Operations:**

clock resetn wr rd

address

DI

DO

- ✓ Writing onto memory (wr rd='1'): The 4-bit input data (DI) is written into one of the 8 registers. The address signal selects which register is to be written.
  - For example: if address = "101", then the value of DI is written into register 5.
  - Note that because the BusMUX 8-to-1 includes an enable input, if wr rd=1, then the BusMUX outputs are 0's.
- Reading from memory (wr\_rd='0'): The address signal selects the register from which data is read. This data appears on the BusMUX output.
  - For example: If address = "010", then data from register 2 appears on BusMUX output.



### **PROBLEM 7 (8 PTS)**

- Attach your Project Status Report (no more than 1 page, single-spaced, 2 columns, only one submission per group). This report should contain the initial status of your project. For formatting, use the provided template (Final Project - Report Template.docx). The sections included in the template are the ones required in your Final Report. At this stage, you are only required to:
  - ✓ Include a (draft) project description and title.
  - ✓ Include a <u>draft</u> Block Diagram of your hardware architecture.



- As a guideline, the figure shows a simple Block Diagram. There are input and output signals, as well as internal components along with their interconnection.
  - At this stage, only a rough draft is required. There is no need to go into details: it is enough to show the tentative toplevel components that would constitute your system as well as the tentative inputs and outputs.
- Only student is needed to attach the report (make sure to indicate all the team members).